|    | Instruction | Operands        | Description                                                                                                                                                                                                                     | Flags Affected                                                                                                                       | assembly code                  |
|----|-------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|
| 1  | ADD         | REG, REG        | operand1 = operand1 + operand2                                                                                                                                                                                                  | ALL Flags                                                                                                                            | 0-<br>00000000<br>1-<br>RRRRRR |
| 2  | AND         | REG, REG        | Logical AND between all bits of two operands. Result is stored in operand1.                                                                                                                                                     | OF=0<br>CF=0<br>SF,ZF are<br>updated                                                                                                 | 0-<br>00000001<br>0-<br>RRRRRR |
| 3  | SUB         | REG, REG        | operand1 = operand1 - operand2<br>sub with 2's complement add                                                                                                                                                                   | ALL Flags                                                                                                                            | 0-<br>00000001<br>1-<br>RRRRRR |
| 4  | OR          | REG, REG        | Logical OR between all bits of two operands. Result is stored in operand1.                                                                                                                                                      | OF=0<br>CF=0<br>SF,ZF are<br>updated                                                                                                 | 0-<br>00000010<br>0-<br>RRRRRR |
| 5  | XOR         | REG, REG        | Logical XOR between all bits of two operands. Result is stored in operand1.                                                                                                                                                     | OF=0<br>CF=0<br>SF,ZF are<br>updated                                                                                                 | 0-<br>00000010<br>1-<br>RRRRRR |
| 6  | MOV         | REG, REG        | Copy operand2 to operand1                                                                                                                                                                                                       | NONE                                                                                                                                 | 0-<br>00000011<br>0-<br>RRRRRR |
| 7  | ADC         | REG             | add operand with carry flag and stored result in operand                                                                                                                                                                        | Same As ADD                                                                                                                          | 0-<br>00000011<br>1-<br>RRRXXX |
| 8  | NOT         | REG             | One's complement negate operand1 = ~ operand1                                                                                                                                                                                   | NONE                                                                                                                                 | 0-<br>00000100<br>0-<br>RRRXXX |
| 9  | SAR         | REG , immediate | Shift Arithmetic operand1 Right. The number of shifts is set by operand2. Shift all bits right, the bit that goes off is set to CF. The sign bit that is inserted to the left-most position has the same value as before shift. | OF=0 if first<br>operand keeps<br>original sign.<br>the bit that goes<br>off is set to CF.<br>SF,ZF are<br>updated after<br>shifting | 0-<br>00000100<br>1- RRRIII    |
| 10 | SLR         | REG , immediate | Shift operand1 Right. (Logical) The number of shifts is set by operand2. Shift all bits right, the bit that goes off is set to CF. Zero bit is inserted to the left-most position.                                              | OF=0 if first operand keeps original sign. the bit that goes off is set to CF. SF,ZF are updated after shifting                      | 0-<br>00000101<br>0- RRRIII    |
| 11 | SAL         | REG , immediate | Shift Arithmetic operand1 Left. The number of shifts is set by operand2.                                                                                                                                                        | OF=0 if first operand keeps original sign.                                                                                           | 0-<br>00000101<br>1- RRRIII    |

|                |                     |                       | Shift all bits left, the bit that goes                                                                                                                                                      | the bit that goes                                |                                                                                                                                                                                          |
|----------------|---------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                |                     |                       | off is set to CF.                                                                                                                                                                           | off is set to CF.                                |                                                                                                                                                                                          |
|                |                     |                       | Zero bit is inserted to the right-<br>most position.                                                                                                                                        | SF,ZF are<br>updated after                       |                                                                                                                                                                                          |
|                |                     |                       | most position.                                                                                                                                                                              | shifting                                         |                                                                                                                                                                                          |
|                |                     |                       |                                                                                                                                                                                             | OF=0 if first                                    |                                                                                                                                                                                          |
|                |                     |                       | Shift operand1 Left. The number of shifts is set by operand2.                                                                                                                               | operand keeps                                    |                                                                                                                                                                                          |
|                |                     | REG,                  | Shift all bits left, the bit that goes                                                                                                                                                      | original sign.<br>the bit that goes              | 0-                                                                                                                                                                                       |
| 12             | SLL                 | immediate             | off is set to CF.                                                                                                                                                                           | off is set to CF.                                | 00000110<br>0- RRRIII                                                                                                                                                                    |
|                |                     |                       | Zero bit is inserted to the right-                                                                                                                                                          | SF,ZF are                                        | 0- KKKIII                                                                                                                                                                                |
|                |                     |                       | most position.                                                                                                                                                                              | updated after<br>shifting                        |                                                                                                                                                                                          |
|                |                     |                       |                                                                                                                                                                                             | OF=0 if first                                    |                                                                                                                                                                                          |
|                |                     |                       | Rotate operand1 right. The number                                                                                                                                                           | operand keeps                                    |                                                                                                                                                                                          |
|                |                     | DEC                   | of rotates is set by operand2.                                                                                                                                                              | original sign.                                   | 0-                                                                                                                                                                                       |
| 13             | ROL                 | REG , immediate       | shift all bits right, the bit that goes                                                                                                                                                     | the bit that goes off is set to CF.              | 00000110                                                                                                                                                                                 |
|                |                     | mmediate              | off is set to CF and the same bit is                                                                                                                                                        | SF,ZF are                                        | 1- RRRIII                                                                                                                                                                                |
|                |                     |                       | inserted to the left-most position.                                                                                                                                                         | updated after                                    |                                                                                                                                                                                          |
|                |                     |                       |                                                                                                                                                                                             | shifting<br>OF=0 if first                        |                                                                                                                                                                                          |
|                |                     |                       | B                                                                                                                                                                                           | operand keeps                                    |                                                                                                                                                                                          |
|                |                     |                       | Rotate operand1 left. The number of rotates is set by operand2.                                                                                                                             | original sign.                                   | 0-                                                                                                                                                                                       |
| 14             | ROR                 | REG,                  | shift all bits left, the bit that goes                                                                                                                                                      | the bit that goes                                | 00000111                                                                                                                                                                                 |
|                |                     | immediate             | off is set to CF and the same bit is                                                                                                                                                        | off is set to CF.<br>SF,ZF are                   | 0- RRRIII                                                                                                                                                                                |
|                |                     |                       | inserted to the right-most position.                                                                                                                                                        | updated after                                    |                                                                                                                                                                                          |
|                |                     |                       |                                                                                                                                                                                             | 1 . C.                                           |                                                                                                                                                                                          |
|                |                     |                       |                                                                                                                                                                                             | shifting                                         |                                                                                                                                                                                          |
|                |                     |                       | operand - operand   1 Ingrement                                                                                                                                                             |                                                  | 0-                                                                                                                                                                                       |
| 15             | INC                 | REG                   | operand = operand + 1. Increment by 1                                                                                                                                                       | ALL (same as                                     | 0-<br>00000111<br>1-                                                                                                                                                                     |
| 15             | INC                 | REG                   | operand = operand + 1. Increment<br>by 1                                                                                                                                                    |                                                  | 00000111                                                                                                                                                                                 |
| 15             | INC                 | REG                   | by 1                                                                                                                                                                                        | ALL (same as ADD)                                | 00000111<br>1-<br>RRRXXX<br>0-                                                                                                                                                           |
| 15             | INC<br>DEC          | REG<br>REG            | by 1 operand = operand - 1. Decrement                                                                                                                                                       | ALL (same as ADD)  ALL (same as                  | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000                                                                                                                                               |
|                |                     |                       | by 1                                                                                                                                                                                        | ALL (same as ADD)                                | 00000111<br>1-<br>RRRXXX<br>0-                                                                                                                                                           |
|                |                     |                       | by 1 operand = operand - 1. Decrement                                                                                                                                                       | ALL (same as ADD)  ALL (same as                  | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000<br>0-<br>RRRXXX<br>0-                                                                                                                         |
|                |                     |                       | by 1 operand = operand - 1. Decrement                                                                                                                                                       | ALL (same as ADD)  ALL (same as                  | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000<br>0-<br>RRRXXX<br>0-<br>00000000                                                                                                             |
| 16             | DEC                 | REG                   | by 1 operand = operand - 1. Decrement by 1                                                                                                                                                  | ALL (same as ADD)  ALL (same as SUB)             | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000<br>0-<br>RRRXXX<br>0-<br>00000000<br>0-                                                                                                       |
| 16             | DEC                 | REG                   | by 1 operand = operand - 1. Decrement by 1                                                                                                                                                  | ALL (same as ADD)  ALL (same as SUB)             | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000<br>0-<br>RRRXXX<br>0-<br>00000000<br>0-<br>XXXXXX<br>0-                                                                                       |
| 16             | DEC                 | REG                   | by 1  operand = operand - 1. Decrement by 1  NONE  Show Value of Register (operand)                                                                                                         | ALL (same as ADD)  ALL (same as SUB)             | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000<br>0-<br>RRRXXX<br>0-<br>00000000<br>0-<br>XXXXXX<br>0-<br>00001001                                                                           |
| 16             | DEC                 | REG<br>NONE           | by 1  operand = operand - 1. Decrement by 1  NONE                                                                                                                                           | ALL (same as ADD)  ALL (same as SUB)             | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000<br>0-<br>RRRXXX<br>0-<br>00000000<br>0-<br>XXXXXX<br>0-<br>00001001<br>0-                                                                     |
| 16             | DEC                 | REG<br>NONE           | by 1  operand = operand - 1. Decrement by 1  NONE  Show Value of Register (operand)                                                                                                         | ALL (same as ADD)  ALL (same as SUB)             | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000<br>0-<br>RRRXXX<br>0-<br>00000000<br>0-<br>XXXXXX<br>0-<br>00001001                                                                           |
| 16<br>17<br>18 | DEC<br>NOP<br>ShowR | REG<br>NONE<br>REG    | by 1  operand = operand - 1. Decrement by 1  NONE  Show Value of Register (operand) on LEDs  concat the Value of two Register                                                               | ALL (same as ADD)  ALL (same as SUB)  NONE       | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000<br>0-<br>RRRXXX<br>0-<br>00000000<br>0-<br>XXXXXX<br>0-<br>00001001<br>0-<br>RRRXXX                                                           |
| 16             | DEC                 | REG<br>NONE           | by 1  operand = operand - 1. Decrement by 1  NONE  Show Value of Register (operand) on LEDs                                                                                                 | ALL (same as ADD)  ALL (same as SUB)             | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000<br>0-<br>RRRXXX<br>0-<br>00000000<br>0-<br>XXXXXX<br>0-<br>00001001<br>0-<br>RRRXXX<br>0-<br>00001001                                         |
| 16<br>17<br>18 | DEC<br>NOP<br>ShowR | REG<br>NONE<br>REG    | by 1  operand = operand - 1. Decrement by 1  NONE  Show Value of Register (operand) on LEDs  concat the Value of two Register                                                               | ALL (same as ADD)  ALL (same as SUB)  NONE       | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000<br>0-<br>RRRXXX<br>0-<br>00000000<br>0-<br>XXXXXX<br>0-<br>00001001<br>0-<br>RRRXXX                                                           |
| 16<br>17<br>18 | DEC  NOP  ShowR     | REG NONE REG REG, REG | by 1  operand = operand - 1. Decrement by 1  NONE  NONE  Show Value of Register (operand) on LEDs  concat the Value of two Register and show on LEDs  Load 8 bits of Dip switches to the    | ALL (same as ADD)  ALL (same as SUB)  NONE  NONE | 00000111 1- RRRXXX 0- 00001000 0- RRRXXX 0- 00000000 0- XXXXXX 0- 00001001 0- RRRXXX 0- 00001001 1- RRRRRR 0- 00001010                                                                   |
| 16<br>17<br>18 | DEC<br>NOP<br>ShowR | REG<br>NONE<br>REG    | by 1  operand = operand - 1. Decrement by 1  NONE  Show Value of Register (operand) on LEDs  concat the Value of two Register and show on LEDs                                              | ALL (same as ADD)  ALL (same as SUB)  NONE       | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000<br>0-<br>RRRXXX<br>0-<br>00000000<br>0-<br>XXXXXX<br>0-<br>00001001<br>0-<br>RRRXXX<br>0-<br>00001001<br>1-<br>RRRRRR<br>0-<br>00001010<br>0- |
| 16<br>17<br>18 | DEC  NOP  ShowR     | REG NONE REG REG, REG | by 1  operand = operand - 1. Decrement by 1  NONE  Show Value of Register (operand) on LEDs  concat the Value of two Register and show on LEDs  Load 8 bits of Dip switches to the Register | ALL (same as ADD)  ALL (same as SUB)  NONE  NONE | 00000111 1- RRRXXX 0- 00001000 0- RRRXXX 0- 00000000 0- XXXXXX 0- 00001001 0- RRRXXX 0- 00001001 1- RRRRRR 0- 00001010 0- RRRXXX                                                         |
| 16<br>17<br>18 | DEC  NOP  ShowR     | REG NONE REG REG, REG | by 1  operand = operand - 1. Decrement by 1  NONE  NONE  Show Value of Register (operand) on LEDs  concat the Value of two Register and show on LEDs  Load 8 bits of Dip switches to the    | ALL (same as ADD)  ALL (same as SUB)  NONE  NONE | 00000111<br>1-<br>RRRXXX<br>0-<br>00001000<br>0-<br>RRRXXX<br>0-<br>00000000<br>0-<br>XXXXXX<br>0-<br>00001001<br>0-<br>RRRXXX<br>0-<br>00001001<br>1-<br>RRRRRR<br>0-<br>00001010<br>0- |

|    |        |                                              |                                                                                                                                                       |      | RRRRR                          |
|----|--------|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------------------------|
| 22 | СМР    | REG, REG                                     | operand1 - operand2 Result is not stored anywhere, flags are set (OF, SF, ZF, CF) according to result.                                                | ALL  | 0-<br>00001011<br>0-<br>RRRRRR |
| 23 | JE     | Address of Data Memory (IM)                  | address of memory that jumps to this if jump happened in operand2 and operand1 is don't care  Condition: ZF = 1                                       | NONE | 1-0000-<br>XXXAAA<br>AAAAA     |
| 24 | JB     | Address of Data Memory (IM)                  | Address of memory that jumps to this if jump happened in operand2 and operand1 is don't care.  Condition: CF = 1  Used for unsigned compare           | NONE | 1-0001-<br>XXXAAA<br>AAAAA     |
| 25 | JA     | Address of Data Memory (IM)                  | Address of memory that jumps to this if jump happened in operand2 and operand1 is don't care.  Condition: CF = 0, ZF=0  Used for unsigned compare     | NONE | 1-0010-<br>XXXAAA<br>AAAAA     |
| 26 | JL     | Address of<br>Data<br>Memory<br>(IM)         | Address of memory that jumps to this if jump happened in operand2 and operand1 is don't care.  Condition: SF not equal to OF  Used for signed compare | NONE | 1-0011-<br>XXXAAA<br>AAAAA     |
| 27 | JG     | Address of<br>Data<br>Memory<br>(IM)         | address of memory that jumps to this if jump happened in operand2 and operand1 is don't care Condition: SF=OF, ZF=0 Used for unsigned compare         | NONE | 1-0100-<br>XXXAAA<br>AAAAA     |
| 28 | JMP    | Address of<br>Data<br>Memory<br>(IM)         | Address of memory that jumps to this in operand2 and operand1 is don't care.  Jump without any condition                                              | NONE | 1-0101-<br>XXXAAA<br>AAAAA     |
| 29 | LI     | REG , immediate                              | Copy immediate value (operand2) to Register (operand1)                                                                                                | NONE | 1-0110-<br>RRRIIIIII<br>I      |
| 30 | LM     | REG,<br>Address of<br>Data<br>Memory<br>(DM) | Load data from data memory<br>(address of memory in operand2)<br>and copy to REG (operand1)                                                           | NONE | 1-0111-<br>RRRAAA<br>AAAAA     |
| 31 | ShowDM | Address of Data Memory (DM)                  | Show data of data memory on<br>LEDs (address of memory in<br>operand2 and operand1 is don't<br>care)                                                  | NONE | 1-1000-<br>XXXAAA<br>AAAAA     |
| 32 | ShowIM | Address of<br>Data<br>Memory<br>(IM)         | Show data of instruction memory<br>on LEDs (address of memory in<br>operand2 and operand1 is don't<br>care)                                           | NONE | 1-1001-<br>XXXAAA<br>AAAAA     |